<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <script>
      const orders = [
        {
          id: 1,
          name: 'John Smith',
          address: '123 Main St',
          status: 'created',
          log: [
            {
              status: 'created',
              time: '2023-02-16 12:30:00',
            },
          ],
        },
        {
          id: 2,
          name: 'Jane Doe',
          address: '456 Second St',
          status: 'packed',
          log: [
            {
              status: 'created',
              time: '2023-02-16 10:00:00',
            },
            {
              status: 'packed',
              time: '2023-02-16 12:30:00',
            },
          ],
        },
        {
          id: 3,
          name: 'Bob Johnson',
          address: '789 Third St',
          status: 'shipped',
          log: [
            {
              status: 'created',
              time: '2023-02-15 10:00:00',
            },
            {
              status: 'packed',
              time: '2023-02-15 12:00:00',
            },
            {
              status: 'shipped',
              time: '2023-02-16 9:00:00',
            },
          ],
        },
        {
          id: 4,
          name: 'Frank Johnson',
          address: '789 Third St',
          status: 'shipped',
          log: [
            {
              status: 'created',
              time: '2023-02-15 10:00:00',
            },
            {
              status: 'packed',
              time: '2023-02-15 12:00:00',
            },
            {
              status: 'shipped',
              time: '2023-02-16 9:00:00',
            },
          ],
        },
      ];

      function getOrdersByStatus(status) {
        const renderData = orders
          .filter((item) => item.status === status)
          .map((item) => {
            const { id, name, address, status, log } = item;
            return {
              id: id,
              name: name,
              address: address,
              status: status,
              log: log.filter((item) => item.status === status),
            };
          })
          .sort((a, b) => {
            a.id - b.id;
          });

        return renderData;
      }
      function getOrderStatusHistory(id) {
        const logs = [];
        let html = ``;
        orders.forEach((item) => {
          if (item.id === id) {
            item.log.forEach((item) => logs.push(item));
          }
        });
        logs.sort((a, b) => Date.parse(a.time) - Date.parse(b.time));
        logs.forEach((item) => {
          html += `[${item.time}] ${item.status} \n`;
        });
        return html;
      }
      console.log(getOrdersByStatus('packed'));
      console.log(getOrderStatusHistory(3));
    </script>
  </body>
</html>
